// 产品分类模型定义文件
// 该文件定义了产品分类数据表的结构和相关配置

const Sequelize = require('sequelize');

/**
 * 定义产品分类模型
 * @param {Sequelize} sequelize - Sequelize实例
 * @param {DataTypes} DataTypes - Sequelize数据类型
 * @returns {Model} 产品分类模型
 */
module.exports = function(sequelize, DataTypes) {
  return sequelize.define('product_categories', {
    // 分类ID字段 - 主键，自增
    category_id: {
      autoIncrement: true,              // 设置为自增字段
      autoIncrementIdentity: true,      // PostgreSQL的自增标识
      type: DataTypes.INTEGER,          // 数据类型为整数
      allowNull: false,                 // 不允许为空
      primaryKey: true                  // 设置为主键
    },
    
    // 分类名称字段
    category_name: {
      type: DataTypes.STRING(50),       // 数据类型为字符串，最大长度50
      allowNull: false,                 // 不允许为空
      unique: "product_categories_category_name_key" // 设置为唯一约束
    },
    
    // 分类描述字段
    description: {
      type: DataTypes.TEXT,             // 数据类型为文本
      allowNull: true                   // 允许为空
    },
    
    // 父分类ID字段（用于构建分类层级结构）
    parent_id: {
      type: DataTypes.INTEGER,          // 数据类型为整数
      allowNull: true                   // 允许为空，null表示顶级分类
    }
  }, {
    sequelize,                          // Sequelize实例
    tableName: 'product_categories',    // 指定数据表名
    schema: 'public',                   // 指定数据库模式
    hasTrigger: true,                   // 表具有触发器
    timestamps: true,                   // 启用时间戳
    createdAt: 'created_at',            // 指定创建时间字段名
    updatedAt: 'updated_at',            // 指定更新时间字段名
    indexes: [                          // 索引定义
      {
        name: "product_categories_pkey", // 主键索引
        unique: true,                   // 唯一索引
        fields: [                       // 索引字段
          { name: "category_id" },      // 索引字段为分类ID
        ]
      },
      {
        name: "product_categories_category_name_key", // 分类名称唯一索引
        unique: true,                   // 唯一索引
        fields: [                       // 索引字段
          { name: "category_name" },    // 索引字段为分类名称
        ]
      },
    ]
  });
};